package com.arsn.myf.system.mapper;

import com.arsn.myf.system.entity.Role;
import com.arsn.myf.system.entity.User;
import com.arsn.myf.system.excel.UserExcel;
import com.arsn.myf.system.vo.UserVO;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Set;

/**
 * 用户mapper 映射层
 * @author zhongrj
 * @time 2021-9-10
 */
@Mapper
public interface UserMapper extends BaseMapper<User> {
    /**
     * 自定义用户分页数据
     * @param page
     * @param user
     * @return
     */
    IPage<UserVO> selectPageUserList(@Param("page") Page<UserVO> page, @Param("user") UserVO user);

    /**
     * 账户唯一检查
     * @param account 账户名
     * @return
     */
    Integer checkAccount(@Param("account") String account);

    /**
     * 根据用户查询权限集合
     * @param user 用户对象信息
     * @return
     */
    Set<String> getMenuPermission(@Param("user") User user);

    /**
     * 根据用户查询角色集合
     * @param user 用户对象信息
     * @return
     */
    Set<String> getRolePermission(@Param("user") User user);

    /**
     * 查询所有用户
     * @param user
     * @return
     */
    List<UserVO> getUserList(@Param("user") UserVO user);

    /**
     * 根据用户ID查询角色信息
     * @param id 用户id
     * @return
     */
    List<Role> getRoleByUserId(@Param("id") Long id);

    /**
     * 查询用户导出数据
     * @param user
     * @return
     */
    List<UserExcel> getExportUserExcelPage(@Param("user") UserVO user);
}
